<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <!-- 引入Element必要的依赖文件 -->
    <link rel="stylesheet" href="../../../plugins/element-ui/lib/theme-chalk/index.css">
    <script src="../../../plugins/vue/vue.js"></script>
    <script src="../../../plugins/element-ui/lib/index.js"></script>
    <script src="../../../plugins/axios/axios.min.js" type="text/javascript"></script>
    <script src="../../../js/request.js"></script>
    <script src="../../../api/admin.js"></script>
    <script src="../../../js/validate.js"></script>
    <script src="../../../js/index.js"></script>

<body>
    <!-- div关联Vue依赖 -->
    <div id="div">
        <!-- 新增数据表单start -->
        <el-form :model="ruleForm" :rules="rules" ref="ruleForm" label-width="100px" class="demo-ruleForm">
            <!-- 管理员姓名 -->
            <el-form-item label="姓名" prop="name">
                <el-input v-model="ruleForm.name" size="small"></el-input>
            </el-form-item>
            <!-- 管理员登录名 -->
            <el-form-item label="登录名" prop="userName">
                <el-input v-model="ruleForm.userName" size="small"></el-input>
            </el-form-item>
            <!-- 管理员登录密码 -->
            <el-form-item label="密码" prop="password">
                <el-input v-model="ruleForm.password" size="small"></el-input>
            </el-form-item>
            <!-- 管理员所在部门，需要在页面创建时发起请求，请求列表 -->
            <el-form-item label="所在部门" prop="deptId">
                <el-select v-model="ruleForm.deptId" placeholder="请选择所属部门">
                    <el-option v-for="(item,index) in deptList" :key="index" :label="item.deptName"
                        :value="item.deptId" />
                </el-select>
            </el-form-item>
            <!--用户状态-->
            <el-form-item label="状态" prop="state">
                <el-radio-group v-model="ruleForm.state">
                    <el-radio label="启用"></el-radio>
                    <el-radio label="禁用"></el-radio>
                </el-radio-group>
            </el-form-item>
            <!-- 操作按钮 -->
            <el-form-item>
                <el-button type="primary" @click="submitForm('ruleForm')">保存</el-button>
                <el-button @click="resetForm('ruleForm')">重置</el-button>
            </el-form-item>
        </el-form>
        <!-- 新增数据表单end -->
    </div>
</body>
<!-- js代码部分 -->
<script>
    // Vue核心对象
    new Vue({
        el: "#div",
        data() {
            return {
                //如果是修改，责标记当前id
                id: '',
                //标记当前状态为新增还是修改
                actionType: '',
                //查询的部门列表数据
                deptList: [],
                //表单提交的数据
                ruleForm: {
                    name: '',
                    userName: '',
                    password: '123456',
                    deptId: '',
                    state: '启用',
                },
                // 数据验证
                rules: {
                    name: [
                        { required: true, message: '请输入姓名', trigger: 'blur' },
                        { min: 1, max: 10, message: '长度在 1 到 10 个字符', trigger: 'blur' }
                    ],
                    userName: [
                        { required: true, message: '请输入登录名', trigger: 'blur' },
                        { min: 1, max: 10, message: '长度在 1 到 10 个字符', trigger: 'blur' }
                    ],
                    password: [
                        { required: true, message: '请输入密码', trigger: 'blur' },
                        { min: 1, max: 20, message: '长度在 1 到 20 个字符', trigger: 'blur' }
                    ],
                }
            };
        },
        //钩子函数，创建页面时被初始化
        created() {
            //加载部门列表数据
            this.getDeptList()
            //从请求路径中获取id数据
            this.id = requestUrlParam('id')
            //判断id是否存在，确定当前是新增还是修改的状态
            this.actionType = this.id ? 'edit' : 'add'
            //如果id存在，则执行初始化方法， 根据id查询数据
            if (this.id) {
                this.init()
            }
        },
        mounted() {

        },
        methods: {
            // 获取部门分类
            getDeptList() {
                getDeptList().then(res => {
                    if (res.code === 1) {
                        this.deptList = res.data
                    } else {
                        this.$message.error(res.msg || '操作失败')
                    }
                })
            },
            //初始化方法：根据id查询单条数据，进行修改时的数据回显
            async init() {
                queryAdminById(this.id).then(res => {
                    console.log(res)
                    if (String(res.code) === '1') {
                        this.ruleForm = res.data
                        this.ruleForm.state = res.data.state === '0' ? '禁用' : '启用'
                    } else {
                        this.$message.error(res.msg || '操作失败')
                    }
                })
            },
            //重置数据的方法
            resetForm(ruleForm) {
                this.ruleForm = {
                    name: '',
                    userName: '',
                    password: '',
                    deptId: '',
                    state: '启用',
                }
            },
            // 提交数据的方法
            submitForm(formName, st) {
                //01.判断数据是否通过验证
                this.$refs[formName].validate((valid) => {
                    if (valid) {
                        //获取要提交的数据
                        let params = {
                            ...this.ruleForm,
                            state: this.ruleForm.state === '启用' ? '1' : '0'
                        }
                        // params.flavors = this.dishFlavors
                        //如果是新增方法，则删除id数据
                        if (this.actionType == 'add') {
                            delete params.id
                            //调用方法，提交数据
                            addAdmin(params).then(res => {
                                //根据返回值进行提示res.code === 1
                                if (res.code === 1) {
                                    parent.index.$message.success('部门添加成功！')
                                    if (!st) {
                                        //重置数据
                                        this.resetForm();
                                        //关闭窗口
                                        parent.index.dialogVisible = false
                                        //刷新数据
                                        parent.index.reloadIframe()
                                    } else {
                                        //重置数据
                                        this.resetForm(ruleForm);
                                    }
                                } else {
                                    parent.index.$message.error(res.msg || '操作失败')
                                }
                            }).catch(err => {
                                parent.index.$message.error('请求出错了：' + err)
                            })
                        } else {
                            //如果是修改的方法，责需要携带id
                            delete params.updateTime
                            editAdmin(params).then(res => {
                                if (res.code === 1) {
                                    parent.index.$message.success('修改成功！')
                                    //关闭窗口
                                    parent.index.dialogVisible = false
                                    //刷新数据
                                    parent.index.handleQuery()
                                } else {
                                    parent.index.$message.error(res.msg || '操作失败')
                                }
                            }).catch(err => {
                                parent.index.$message.error('请求出错了：' + err)
                            })
                        }
                    } else {
                        return false
                    }
                })
            },

        }
    });
</script>

</html>